package com.kobeliu.entity;

/**
 * LeetCode 876
 *
 * 给定一个头结点为 head 的非空单链表，返回链表的中间结点。
 *
 * 如果有两个中间结点，则返回第二个中间结点。
 *
 *
 *
 * 示例 1：
 *
 * 输入：[1,2,3,4,5]
 * 输出：此列表中的结点 3 (序列化形式：[3,4,5])
 * 返回的结点值为 3 。 (测评系统对该结点序列化表述是 [3,4,5])。
 * 注意，我们返回了一个 ListNode 类型的对象 ans，这样：
 * ans.val = 3, ans.next.val = 4, ans.next.next.val = 5, 以及 ans.next.next.next = NULL.
 *
 * 示例 2：
 *
 * 输入：[1,2,3,4,5,6]
 * 输出：此列表中的结点 4 (序列化形式：[4,5,6])
 * 由于该列表有两个中间结点，值分别为 3 和 4，我们返回第二个结点。
 */

public class Demo_45_No876 {

    class ListNode {
      int val;
      ListNode next;
      ListNode() {}
      ListNode(int val) { this.val = val; }
      ListNode(int val, ListNode next) { this.val = val; this.next = next; }
    }



    public ListNode middleNode(ListNode head) {


        //双指针 ，一个指针走两步/次 ，一个指针走一步/次
        //前面指针到头，胡一个指针在中间位置
        ListNode temp1 = head; //一次一步
        ListNode temp2 = head; //一次两步

        while(temp2!=null && temp2.next!=null){
            temp1 = temp1.next;
            temp2 = temp2.next.next;
        }
        return temp1;

    }
}
